פתרון מוצע לבחינת מה"ט ב_שפת c מועד אביב תשע"ח, פברואר 8102 מחבר: מר שייקה בילו, מכללת אורט רחובות

Size: px
Start display at page:

Download "פתרון מוצע לבחינת מה"ט ב_שפת c מועד אביב תשע"ח, פברואר 8102 מחבר: מר שייקה בילו, מכללת אורט רחובות"

Transcription

1 פתרון מוצע לבחינת מה"ט ב_שפת c מועד אביב תשע"ח, פברואר 8102 מחבר: מר שייקה בילו, מכללת אורט רחובות שאלה מספר 1 התוכנית מגדירה חמישה משתנים שלמים: השלושה הראשונים הם שלושה מצביעים - *s *t,i. j ושלושה נוספים הם שני זקיפים r* מבצעים השמה של כתובת המשתנה מקושרים. מבצעים השמה של כתובת המשתנה מקושרים. i לתוך שדה הכתובת של המשתנה s j חתוך שדה הכתובת של המשתנה מבצעים השמה של שדה הכתובת הנמצא בתוך המשתנה המשתנה r כך שהם כעת מקושרים. מבצעים השמה של שדה הכתובת הנמצא בתוך המשתנה המשתנה s כך שהם כעת מקושרים. מבצעים השמה של שדה הכתובת הנמצא בתוך המשתנה המשתנה t כך שהם כעת מקושרים. הדפסה ראשונה: כעת מדפיסים את שני הזקיפים שהוכנסו לאחר האתחול: הדפסה שנייה: t s t r i ו- j 5 7 כך שהם כעת כך שהם כעת לתוך שדה הכתובת של חתוך שדה הכתובת של לתוך שדה הכתובת של ומקבלים על המסך את שני הערכים שלהם כפי במקטע זה התוכנית מבצעת החלפה בין שני המשתנים המקוריים מתמטית בין המצביעים אשר מקושרים לשני המשתנים ערכם של i ו- j התחלפו וב- i יש כעת 7 וב- j יש כעת 5. כעת מדפיסים את שני הזקיפים ההחלפה: הדפסה שלישית: i. ו- j i i ו- j 7 5 במקטע זה התוכנית מבצעת לולאה המתחילה מ- ערכו ע"י ביצוע החלפה ו- j לאחר החלפה המתמטית ומקבלים על המסך את שני הערכים שלהם לאחר i=9 ומתקדמת עד ש- i קטן שווה,01 כלומר מבצעת שני סיבובים. בכל סיבוב נבדק האם המשתנה זקיף i גדול מ- 9 או לחילופין הוא בהפחתה עצמית של 0 קטן מ- 9, כל זמן שהתנאי הזה נכון המשתנה זקיף i עולה ב- 0. בסיבוב הראשוןשל הלולאה יודפס 9 כי הזקיף עומד בתנאי של בהיותו 2 הוא קטן מ- 9 ואז עולה ב- 0 ומודפס הערך.9 בסיבוב השני המשתנה עולה ל- 01 i ונכנס ללולאה ואז נבדק האם הוא גדול מ- 9, כיוון שהתשובה אמת ערכו עולה ב- 0 והוא הזקיף i הופך ל- 00 ואז עמוד 0

2 מודפס. כיוון שכעת הוא 00 הוא גדול מ- 01 כך שתנאי הקיום של הלולאה מסתיים והתוכנית מבצעת ירידת שורה ומסתיימת. #include<stdio.h> שאלה מספר 2 int func(int data[5][5]) int sumcol = 0, maxcolsum = 0, indexmaxcol, times; int i, j, limit=4, rounds, mod; for (i = 0; i < 5; i++) if (data[0][i] <= limit) for (j = 1; j <= data[0][i]; j++) printf("+%d", data[j][i]); sumcol += data[j][i]; else rounds = data[0][i] / 4; mod = data[0][i] % 4; while (rounds--) for (j = 1; j <= limit; j++) printf("+%d", data[j][i]); sumcol += data[j][i]; for (j = 1; j <= mod; j++) printf("+%d", data[j][i]); sumcol += data[j][i]; printf("=%d", sumcol); if (sumcol > maxcolsum) maxcolsum = sumcol; indexmaxcol = j; printf("\nmatrix Sum Col %d is %d\n\n", i+1, sumcol); sumcol = 0; עמוד 8

3 return maxcolsum; int main() int data[5][5] = 6,7,4,3,8,1,1,2,1,1,2,1,2,1,2, 3,1,1,2,1,2,1,1,8,2 ; int i, j,maxcolsum; printf("matrix[%d][%d]:\n",5,5); for (i = 0; i < 5; i++) for (j = 0; j < 5; j++) printf("%3d", data[i][j]); printf("\n"); printf("\n"); maxcolsum=func(data); printf("max Col Sum is %d\n", maxcolsum); return 0; Output: Matrix[5][5]: = 11 Matrix Sum Col 1 is = 7 Matrix Sum Col 2 is = 6 Matrix Sum Col 3 is = 4 Matrix Sum Col 4 is = 12 Matrix Sum Col 5 is 12 Max Col Sum is 12 עמוד 3

4 #include <stdio.h> #include <stdlib.h> #include <conio.h> שאלה מספר 3 /* Typedef struct name Node */ typedef struct Node int num; struct Node *next; Node; /* Menu selection */ int menu_select() int c; printf("============ L I S T - 1 =========\n"); printf(" 1. Add New Node to List 1 \n"); printf(" 2. Print List 1 + Count Nodes \n"); printf(" 3. Free List 1 \n"); printf("============ L I S T - 2 =========\n"); printf(" 4. Add New Node to List 2 \n"); printf(" 5. Print List 2 + Count Nodes \n"); printf(" 6. Free List 2 \n"); printf("======== Check Lists Sum =========\n"); printf(" 7. Compere List Nodes Sum \n"); printf("============ Concatenating =======\n"); printf(" 8. Combine List 1 & List 2 \n"); printf(" 9. Print new combined list \n"); printf("10. Free new combined List \n"); printf("11. Exit from program \n"); printf("==================================\n"); do printf("\nenter your choice:"); scanf("%d", &c); while (c<0 c>11); return c; /* Initialize the List with input number.*/ Node *Add(Node *head, int number) Node *tail = head; Node *new_item = (Node*)malloc(sizeof(Node)); new_item->num = number; new_item->next = NULL; if (tail == NULL) return new_item; עמוד 4

5 while (tail->next!= NULL) tail = tail->next; tail->next = new_item; return head; /* Count Nodes in List */ int Count_List(Node *head) int counter = 0; while (head!= NULL) counter++; head = head->next; return counter; /* Sum Nodes in List */ int Sum_List_Nodes(Node *head) int sum = 0; while (head!= NULL) sum += head->num; head = head->next; return sum; /* Free List */ void Free_List(Node *head) Node *to_free = head; while (to_free!= NULL) head = head->next; free(to_free); to_free = head; printf("the list is free and deleted!!!\n"); /* Display List on screen */ void Print_List(Node *head) Node *p; for (p = head; p!= NULL; p = p->next) עמוד 5

6 printf("node number is %d next place is %p\n", p- >num, p->next); if (p == NULL) printf("end Of list!!!\n"); return; /* Combine List1 with List2 */ Node *combine_lists(node *List1, Node *List2) Node *List1_head = List1; Node *List2_head = List2; int sumlist1 = 0, sumlist2 = 0; Summing List2 while (List1_head!= NULL) sumlist1 += List1_head->num; List1_head = List1_head->next; Summing List2 while (List2_head!= NULL) sumlist2 += List2_head->num; List2_head = List2_head->next; Chacking Lists sum for concatenating if (sumlist1 > sumlist2) while (List1->next!= NULL) List1 = List1->next; List1->next = List2; Moving on List2 to the end while (List2->next!= NULL) List2 = List2->next; Putting in the last node of List2 the head of List1 List2->next = List1_head; return List1_head; else while (List2->next!= NULL) List2 = List2->next; List2->next = List1; Moving on List1 to the end while (List1->next!= NULL) List1 = List1->next; עמוד 6

7 List2 Putting in the last node of List1 the head of List1->next = List2_head; return List2_head; /* Main program */ int main() int num = 0; int count; int SumList1 = 0, SumList2 = 0; int choice; int input = 0; Node *head1 = NULL; Node *head2 = NULL; for (;;) choice = menu_select(); switch (choice) case 1: printf("enter number to create new node(-1 to exit):\n"); scanf("%d", &input); while (input!= -1) head1 = Add(head1, input); printf("enter number to create new node(- 1 to exit):\n"); scanf("%d", &input); case 2: printf("list 1:\n"); Print_List(head1); count = Count_List(head1); printf("list 1 as %d Nodes\n", count); case 3: Free_List(head1); case 4: printf("enter number to create new node(-1 to exit):\n"); scanf("%d", &input); while (input!= -1) head2 = Add(head2, input); עמוד 7

8 printf("enter number to create new node(- 1 to exit):\n"); scanf("%d", &input); case 5: printf("list2:\n"); Print_List(head2); count = Count_List(head2); printf("list2 as %d Nodes\n", count); case 6: Free_List(head2); case 7: SumList1 = Sum_List_Nodes(head1); printf("list1 Sum Nodes: %d\n", SumList1); SumList2 = Sum_List_Nodes(head2); printf("list2 Sum Nodes: %d\n", SumList2); if (SumList1 > SumList2) printf("list1 Nodes sum is Bigger %d\n", SumList1); else printf("list2 Nodes sum is Bigger %d\n", SumList2); case 8: combine_lists(head1, head2); printf("list1 and List2 Combined!!!\n"); case 9: printf("new Combined List:\n"); if (SumList1 > SumList2) Print_List(head1); else Print_List(head2); case 10: Free_List(head1); case 11: exit(0); getch(); system("cls"); return 0; Output: == == == == == == L I S T - 1 == == == == = 1. Add New Node to List 1 2. Print List 1 + Count Nodes 3. Free List 1 עמוד 2

9 == == == == == == L I S T - 2 == == == == = 4. Add New Node to List 2 5. Print List 2 + Count Nodes 6. Free List 2 == == == == Check Lists Sum == == == == = 7. Compere List Nodes Sum == == == == == == Concatenating == == == = 8. Combine List 1 & List 2 9. Print new combined list 10. Free new combined List 11. Exit from program == == == == == == == == == == == == == == == == == Enter your choice: 9 New Combined List: Node number is 7 next place is 004EF478 Node number is 8 next place is 004EF4D0 Node number is 9 next place is 004EF528 Node number is 6 next place is 0049AAB0 Node number is 2 next place is 004D4A70 Node number is 4 next place is 004D4AC8 Node number is 3 next place is 004D4B20 Node number is 5 next place is 004D4B78 Node number is 6 next place is 004D4BD0 Node number is 7 next place is End Of list!!! #include<stdio.h> #include<string.h> #include<stdlib.h> שאלה מספר 4 char *new_str(char *str1, char *str2) int str1len, str2len, str3len, times; char *str3 = NULL; str1len = strlen(str1); str2len = strlen(str2); printf("str1 \"%s\"\tlen=%2d\nstr2 \"%s\"\tlen=%2d\n",str1, str1len, str2, str2len); if (str1len < str2len) printf("str1 is the short one!!!\n"); times = (str2len - str1len + 1); str3len=str1len + (str2len - str1len + 1)*str1len; printf("new Str3 will have length of %d\n", ++str3len); עמוד 9

10 else str3 = (char *)malloc(str3len * sizeof(char*)); strcpy(str3, str1); while (times) strncat(str3, str2, 4); str2++; times--; printf("str2 is the short one!!!\n"); times = (str1len - str2len + 1); str3len = str2len + (str1len - str2len + 1)*str2len; printf("new Str3 will have length of %d\n", ++str3len); str3 = (char *)malloc(str3len * sizeof(char*)); strcpy(str3, str2); while (times) strncat(str3, str1, 4); str1++; times--; return str3; int main() char *str1 = "abcdefgh"; char *str2 = "good"; Option 2: char *str2 = "abcdefgh"; char *str1 = "good"; Option 3: char *str2 = "abcdefgh"; char *str1 = "goodvibe"; char *str3; str3=new_str(str1, str2); printf("new str3 is \"%s\"\n", str3); return 0; Output 1: Str1 "abcdefgh" length = 8 Str2 "good" length = 4 Str2 is the short one!!! New Str3 will have length of 25 עמוד 01

11 New str3 is "goodabcdbcdecdefdefgefgh" Output for Option 2 (str1 short then str2): Str1 "good" length = 4 Str2 "abcdefgh" length = 8 Str1 is the short one!!! New Str3 will have length of 25 New str3 is "goodabcdbcdecdefdefgefgh" Output for Option 2 (str1 length equal to str2): /*Str1 "goodvibe" length = 8 Str2 "abcdefgh" length = 8 Str2 is the short one!!! New Str3 will have length of 17 New str3 is "abcdefghgood*/ 1, 4, 6, 8, 9, 11, 14, 16, 18, 19, enter number : 24 Yes!!: , 4, 6, 8, 9, 11, 14, 16, 18, 19, enter number : 21 No!! שאלה מספר 5 א. התוכנית תדפיס את התוצאות הבאות עבור המשתנים: 1, 4, 6, 8, 9, 11, 14, 16, 18, 19, enter number : 17 Yes!!: 1 16 התוכנית מגדירה מערך ומאתחלת אותו ב- 01 מספרים. בנוסף מוגדרים מספר משתנים: שני זקיפים j-וi משתנה דגל flag ומשתנה מספר num המיועד עבור קלט מהמשתמש. התוכנית מדפיס את המערך המאותחל ואז קולטת מהמשתמש מספר שלם ובודקת האם יש במערך זוג מספרים שסכומם שווה לערכו של המספר שנקלט, ברגע שנמצא זוג כזה ערכו של הדגל הופך ל- 0 הלולאה מסתיימת והזוג מודפס יחד עם המילה,Yes!! אחרת מודפס.No!! ב. עמוד 00

12 שאלה מספר 6 א. התוכנית תדפיס את התוצאות הבאות: 7, 6, 5, 4, 3, הפונקציה הרקורסיבית sec_req() קולטת את המחרוזת של המספרים מהתוכנית הראשית. במידה והמחרוזת ריקה מסיימים את הקריאות הרקורסיביות. בקריאה לרקורסיה נבדק האם ערכו של תו במחרוזת +0 שווה לשכנו מימין. אם התשובה היא כן, הדגל f מקבל את הערך 0 ועוברים לתו הבא ובכך בודקים את הזוג הבא, במידה ולא הופכים את הדגל ל- 1 ושוב בודקים את הזוג הבא. בסיום נקבל את סדרת המספרים שבמחרוזת אשר עומדים בתנאי שיש תמיד אחד מימינם הגדול מהם ב גדול מ- ב 3 5-0, גדול מ- 4 ב- 0, 6 גדול מ- 5 ב- 0, 7 גדול מ- 6 ב- 0. ל- 0 שבמערך אין שכן 8 וכנ"ל לגבי 9 שאין קטן ממנו ב- 0. ב. שאלה מספר 7 א. ב. התוכנית תדפיס את התוצאות הבאות: hello exam2018 smalllarge הפונקציה func() קולטת מחרוזת הנשלחת מהתוכנית הראשית לתוך מצביע מחרוזתי. מגדירה שני מצביעים *str1 ו- *str2 המיועדים לקליטת מחרוזות בהמשך וכן שלושה זקיפים,i.,j k לשני המצביעים המקומיים מבצעת הפונקציה הקצאת זיכרון בודד אחד מטיפוס תווי וסוגרת את שתי המחרוזות בתו '0\', כמו כן היא מאפסת את שני הזקיפים j ו- k. בהמשך הפונקציה עוברים על המחרוזת שנקלטה עד לסיומה ומבצעים בתוך לולאת המעבר שתי בדיקות: הראשונה בודקת האם התו הנבדק הוא אות גדולה או שווה ל- )97( a במידה וכן מבצעים את הבדיקה השנייה האם התו הנבדק מרחקו מהתו a לפי טבלת אסקי קטן או שווה ל- 38 שהוא המרחק בין )97( a ל- )088(. z משמעות בדיקה זו היא לוודא שהתו שייך לקבוצת האותיות הקטנות. במידה והתשובה היא אמת מגדילים את הזקיף j, מקצים זיכרון נוסף למחרוזת *str1 ומכניסים למחרוזת הראשונה *str1 את התו שנבדק כך שכל האותיות הקטנות בסיום המעבר על המחרוזת ימצאו במחרוזת הראשונה.*str1 אחרת, כלומר אם התו שנבדק ערכו קטן מהתו )97( a לפי טבלת אסקי שהמשמעות היא כי הוא אינו אות קטנה מגדילים את הזקיף k ומקצים זיכרון נוסף למחרוזת *str2 ומכניסים את התו למחרוזת השנייה *str2 כך שכל התווים במחרוזת שאינם אותיות קטנות כלומר אותיות גדולות, ספרות ורווחים יוכנסו למחרוזת.*str2 לאחר סיום המעבר על המחרוזת המקורית כל האותיות הקטנות ימצאו במחרוזת *str וכל שאר התווים ימצאו במחרוזת.*str2 כעת מבצעים שרשור של שתי המחרוזות הראשונה *str1 המכילה את האותיות הקטנות והשנייה *str2 לתוך המחרוזת.*str1 כעת משחררים את הקצאת הזיכרון של המצביע *str2 ומחזירים את כתובת המצביע str1 לתוכנית הראשית. עמוד 08

13 שאלה מספר 8 א. ב. ג. הפונקציה func() קבלת מספר הקסהדצימלי ומייצרת בתוכה תוך כדי שימוש בהזזות ספרה בינארית שהיא חלק מהמספר הבינארי בעל 2 ספרות המייצג את המספר ההקסהדצימלי שנשלח אליה. ע"י שימוש בלולאה התוכנית שולחת לפונקציה כל פעם מספר כאשר היא מקטינה אותו כל סיבוב וכך אם נדפיס את על ההחזרות של הפונקציה נקבל את המספר הבינארי המיצג את ההקסדצימלי שנשלח. להלן מספר דוגמאות: כאשר נשלח המספר 0x74 מתוך הלולאה נקבל בחזרה אחרי כל הסיבובים את כל הספרות המייצגות אותו בבסיס בינארי: אם נתרגם מספר זה למספר דצימלי נקבל 111 שהוא ייצוג של 74 בהקסהדצימלי. כאשר נשלח המספר 0xdc מתוך הלולאה נקבל בחזרה אחרי כל הסיבובים את כל הספרות המייצגות אותו בבסיס בינארי: אם נתרגם מספר זה למספר דצימלי נקבל 220 שהוא ייצוג של DC בהקסהדצימלי. כאשר נשלח המספר 0xfe מתוך הלולאה נקבל בחזרה אחרי כל הסיבובים את כל הספרות המייצגות אותו בבסיס בינארי: אם נתרגם מספר זה למספר דצימלי נקבל 254 שהוא ייצוג של FE בהקסהדצימלי. כאשר נשלח המספר 0x8b מתוך הלולאה נקבל בחזרה אחרי כל הסיבובים את כל הספרות המייצגות אותו בבסיס בינארי: אם נתרגם מספר זה למספר דצימלי נקבל 139 שהוא ייצוג של 8B בהקסהדצימלי. התוכנית מגדירה חמישה משתנים: הראשון num הוא תווי בו מתבצעת השמה של מספר הקסהדצימלי, האחרים הם משתנים שלמים:,i curr,,p err ומאפסת את p ואת.err כעת מתבצעת לולאה אשר מבצעת 2 סיבובים ובכל סיבוב היא שולחת את המספר ההקסהדצימלי לפונקציה לאחר הזזה של מקום אחד ימינה. בכל סיבוב של הלולאה הפונקציה מחזירה ספרה 1 או 0. הערך המוחזר מהפונקציה מסתכם לתוך המשתה p. לאחר סיום הלולאה בתוך המשתנה p יש את מספר ה- 0 המרכיבים את המספר הבינארי שהוא התרגום של המספר ההקסהדצימלי שנשלח לפונקציה כי שניתן לראות בדוגמאות שבסעיף א'. בהמשך נבדק האם המשתנה p הוא אי זוגי, כלומר מספר ה- 0 בו מתחלק ב- 8 עם שארית, במקרה כזה לתוך המשתנה err יוכנס הערך 0 כלומר יש שגיאה ומספר ה- 0 במספר הוא אי זוגי. לאחר מכן ייבדק האם המשתנה err מכיל 1, כלומר מספר ה- 0 במספר הוא זוגי במקרה כזה יודפס: number is OK ונרד שורה, במידה ומספר ה- 0 אינו זוגי יודפס: error ונרד שורה. התוכנית תדפיס את התשובות הבאות: number is OK error error number is OK עבור num = 0x74 יודפס : עבור num = 0xdc יודפס : עבור num = 0xfe יודפס : עבור num = 0x8b יודפס : עמוד 03

Engineering Programming A

Engineering Programming A Engineering Programming A תרגול 5 25.11.2012 מערכים חד-מימדיים )תזכורת( לדוגמא: מערך בשם Arr בגודל 8 שאיבריו מטיפוס int 3 7 5 6 8 1 23 16 0 1 2 3 4 5 6 7 ב - arr[0] ב יושב ערך שהוא המספר השלם 3 arr[1]

More information

Algorithms. Intro2CS week 5

Algorithms. Intro2CS week 5 Algorithms Intro2CS week 5 1 Computational problems A computational problem specifies an inputoutput relationship What does the input look like? What should the output be for each input? Example: Input:

More information

פתרון מוצע לבחינה בשפת C של מה"ט מועד אביב תשע"ז, פברואר 2017 מחבר: מר עסאקלה שאדי, מכללת אורט בראודה

פתרון מוצע לבחינה בשפת C של מהט מועד אביב תשעז, פברואר 2017 מחבר: מר עסאקלה שאדי, מכללת אורט בראודה פתרון מוצע לבחינה בשפת C של מה"ט מועד אביב תשע"ז, פברואר 2017 מחבר: מר עסאקלה שאדי, מכללת אורט בראודה שאלה מספר 1 נתונה התכנית הבאה בשפת C: #include #define SUM_OF_3(x,y,z) x+y+z #define AVRG_OF_3(x,y,z)

More information

קורס תכנות שיעור שישי: מחרוזות, מצביעים

קורס תכנות שיעור שישי: מחרוזות, מצביעים קורס תכנות שיעור שישי: מחרוזות, מצביעים מערכים אוסף סדור של משתנים מאותו סוג המשתנים נמצאים ברצף בזיכרון העברת מערך לפונקציה Define רקורסיה במערך מערכים דו מימדיים 2 מחרוזות מהי מחרוזת? רצף של תוים ייצוג

More information

משתנים שעור מס. 2 כל הזכויות שמורות דר ' דרור טובי המרכז האוניברסיטאי אריאל 1

משתנים שעור מס. 2 כל הזכויות שמורות דר ' דרור טובי המרכז האוניברסיטאי אריאל 1 משתנים שעור מס. 2 דרור טובי דר' כל הזכויות שמורות דר ' דרור טובי המרכז האוניברסיטאי אריאל 1 תפקיד המשתנים הצהרה על משתנה השמת ערך במשתנה int a, b, c; a = 1234; b = 99; c = a + b; משתנים מאפשרים לנו לשמור

More information

תרגול 4 פונקציות. מבנה של פונקציה: public static <return value type> <function name> (<arg1 type> <arg1>, <arg2 type> <arg2>, ) { <function body> }

תרגול 4 פונקציות. מבנה של פונקציה: public static <return value type> <function name> (<arg1 type> <arg1>, <arg2 type> <arg2>, ) { <function body> } נושאי התרגול: מה הן פונקציות הגדרת פונקציה,קריאה לפונקציה העברת ארגומנטים,החזרת ערך או void העברת משתנים פרימיטיביים ומערכים לפונקציה העמסה של פונקציות תרגול 4 פונקציות מוטיבציה לעיתים,אנו נזקקים לבצע

More information

מבוא לתכנות בשפת C. Tzachi (Isaac) Rosen

מבוא לתכנות בשפת C. Tzachi (Isaac) Rosen מבוא לתכנות בשפת C מצביעים והקצאה דינאמית כתובות של משתנים לכל משתנה כתובת של המקום שלו בזיכרון כבר ראינו: שם של מערך הוא למעשה הכתובת של התא הראשון )באינדקס 0( של המערך להזכירכם: תא של מערך הינו משתנה

More information

תרגילים ופתרונות בשפת - C הסתעפויות

תרגילים ופתרונות בשפת - C הסתעפויות תרגילים ופתרונות בשפת - C הסתעפויות כתב וערך: שייקה בילו תרגיל - 1 כתוב תוכנית שתקבל מהמשתמש שלושה מספרים, ותציג את הגדול מביניהם על המסך. #include void main() int mis1, mis2, mis3, max; printf("please

More information

סכום (סדרת ערכים) אחרת - דוגמא: סכום-ספרות (num) אם < 10 num החזר 1 או אם = 0 = num החזר 0 public static int numofdigits (int num)

סכום (סדרת ערכים) אחרת - דוגמא: סכום-ספרות (num) אם < 10 num החזר 1 או אם = 0 = num החזר 0 public static int numofdigits (int num) 1 תבנית צבירה תבניות אלגוריתמיות לפעולות רקורסיביות תבנית צבירה לסדרת ערכים: סכום (סדרת ערכים) החזר את ערך הקצה + סכום (סדרת הערכים ללא ערך הקצה) דוגמא: פעולה המחזירה את סכום הספרות שבמספר שלם לא שלילי

More information

לתיכנות עם MATLAB Lecture 5: Boolean logic and Boolean expressions

לתיכנות עם MATLAB Lecture 5: Boolean logic and Boolean expressions מבוא לתיכנות עם MATLAB 23427 Lecture 5: Boolean logic and Boolean expressions Written by Prof. Reuven Bar-Yehuda, Technion 203 Based on slides of Dr. Eran Eden, Weizmann 2008 ביטויים לוגיים דוגמא: תקינות

More information

Practical Session - Heap

Practical Session - Heap Practical Session - Heap Heap Heap Maximum-Heap Minimum-Heap Heap-Array A binary heap can be considered as a complete binary tree, (the last level is full from the left to a certain point). For each node

More information

מבוא לתכנות ב- JAVA מעבדה 2

מבוא לתכנות ב- JAVA מעבדה 2 מבוא לתכנות ב- JAVA מעבדה 2 מה בתרגול טיפוסים פרימיטיביים המרות טיפוסים אופרטורים יחסיים ולוגיים משפט if-else בתרגול הקודם טיפוסים פרימיטביים לייצוג מספרים שלמים וממשיים ואופרטורים לפעולות בין מספרים.1

More information

Amortized Analysis, Union-Find,

Amortized Analysis, Union-Find, Practical Session No. 13 Amortized Analysis, Union-Find, AMORTIZED ANALYSIS Refers to finding the average running time per operation, over a worst-case sequence of operations. Amortized analysis differs

More information

שאלה 1 מהו הפלט של התוכנית הבאה:

שאלה 1 מהו הפלט של התוכנית הבאה: תרגול חזרה שאלה 1 מהו הפלט של התוכנית הבאה: public sttic int wht(int n) { int i; int sum=0; if(n == 0) return 1; for (i=0; i

More information

מבוא לתכנות ב- JAVA תרגול 7

מבוא לתכנות ב- JAVA תרגול 7 מבוא לתכנות ב- JAVA תרגול 7 רקורסיה - הקדמה הגדרה רקורסיבית: חדר הוא מסודר אם צד שמאל שלו מסודר שלו מסודר. וצד ימין שיטת פתרון רקורסיבית: פתרון מופעים פשוטים יותר של בעיה בכדי לפתור את הבעיה המקורית רקורסיה

More information

קורס תכנות שיעור שני: שימוש במשתנים,

קורס תכנות שיעור שני: שימוש במשתנים, קורס תכנות שיעור שני: שימוש במשתנים, בקרת זרימה, לולאות 1 נושאי השיעור היום משתנים )variables( טיפוסי משתנים בשפת C הגדרת משתנים השמה למשתנים פעולות על משתנים קליטת ערכים מהמשתמש הדפסה משתנים בקרת זרימה

More information

מדעי המחשב 2 יחידות לימוד פתרון בחינת הבגרות פרק א. I x > a. פתרון 2: משפט switch

מדעי המחשב 2 יחידות לימוד פתרון בחינת הבגרות פרק א. I x > a. פתרון 2: משפט switch 1 מדעי המחשב 2 יחידות לימוד פתרון בחינת הבגרות שאלה פרק א :1 m a b k k b x I x > a II x < b פלט I && II 0 8 12 8 4 1 9 11 2 10 11 9 8 2 12 35 13 העמודות המסומנות בכחול אינן עמודות חובה בפתרון. שאלה 2:

More information

מבוא לתכנות תוכנית שעור מס. 1 1 דר' דרור טובי, המרכז האוניברסיטאי אריאל בשומרון.

מבוא לתכנות תוכנית שעור מס. 1 1 דר' דרור טובי, המרכז האוניברסיטאי אריאל בשומרון. מבוא לתכנות תוכנית ראשונה שעור מס. 1 דרור טובי דר' 1 מבוא לתכנות בשפת ++C C \ שלום!! מרצה ד"ר דרור טובי, drorto@ariel.ac.il שעות קבלה: יום ב, 10-12 טלפון )אריאל( 03 9076547 אתר הקורס: http://www.ariel.ac.il/cs/pf/tdror/courses/cpp

More information

לתיכנות עם MATLAB Lecture 5: Boolean logic and Boolean expressions

לתיכנות עם MATLAB Lecture 5: Boolean logic and Boolean expressions מבוא לתיכנות עם MATLAB 234127 Lecture 5: Boolean logic and Boolean expressions Written by Prof. Reuven Bar-Yehuda, Technion 2013 Based on slides of Dr. Eran Eden, Weizmann 2008 1 >>g = [89 91 80 98]; >>p

More information

Programming in C תרגול 8

Programming in C תרגול 8 Programming in C תרגול 8 1 1 נושאים מצביעים רקע אופרטורים על מצביעים מצביעים כפרמטרים לפונקציה הקצאת זיכרון דינאמית Malloc free מצביעים תאור הזיכרון של המחשב: ניתן לחשוב על זיכרון המחשב כעל רצף של תאים,

More information

חוברת תרגילים לתרגול יסודות התכנות

חוברת תרגילים לתרגול יסודות התכנות פעולות קלט ופלט חוברת תרגילים לתרגול יסודות התכנות קלוט 3 מספרים. סכם אותם, הצג את שלושתם ואת תוצאת הסיכום. int num1, num2, num3,sum; Console.WriteLine("please enter 3 numbers"); num1 = int.parse(console.readline());

More information

גירסה

גירסה גירסה 1.00 29.02.2004 לולאות בשפת C מסמך זה הורד מהאתר.http://underwar.livedns.co.il אין להפיץ מסמך זה במדיה כלשהי, ללא אישור מפורש מאת המחבר. מחבר המסמך איננו אחראי לכל נזק, ישיר או עקיף, שיגרם עקב השימוש

More information

מבוא למדעי המחשב תרגול 13: עצים בינאריים

מבוא למדעי המחשב תרגול 13: עצים בינאריים מבוא למדעי המחשב תרגול 13: עצים בינאריים עצים בינאריים - הגדרה הגדרה: עץ בינארי הוא עץ ריק (בלי צמתים) או עץ המורכב משורש ושני תתי-עצים, הוא עץ בינארי. ימני ושמאלי, שכל אחד מהם תרגיל 1 עץ בינארי מסודר

More information

מבוא למדעי המחשב תירגול 2: מבוא למדעי המחשב מ' - תירגול 2

מבוא למדעי המחשב תירגול 2: מבוא למדעי המחשב מ' - תירגול 2 מבוא למדעי המחשב תירגול 2: לולאות, קלט, וטיפוסים 1 תוכנייה לולאת while קלט טיפוסי משתנים המרת טיפוסים טיפוס char 2 לולאת while 3 לולאת while קטע קוד מתבצע שוב ושוב כל עוד תנאי מתקיים int number = 40; while(number>0)

More information

לתיכנות עם MATLAB Lecture 5: Boolean logic and Boolean expressions

לתיכנות עם MATLAB Lecture 5: Boolean logic and Boolean expressions מבוא לתיכנות עם MATLAB 234127 Lecture 5: Boolean logic and Boolean expressions Written by Prof. Reuven Bar-Yehuda, Technion 2013 Based on slides of Dr. Eran Eden, Weizmann 2008 1 motivation Proper academic

More information

מבוא למדעי המחשב תירגול 3:

מבוא למדעי המחשב תירגול 3: מבוא למדעי המחשב תירגול 3: לולאות, קלט, וטיפוסים תוכנייה לולאת while קלט טיפוסי משתנים המרת טיפוסים טיפוס char מבוא למדעי המחשב מ' - תירגול 3 2 לולאת while מבוא למדעי המחשב מ' - תירגול 3 3 לולאת while

More information

Communication Networks ( ) / Spring 2011 The Blavatnik School of Computer Science, Tel-Aviv University. Allon Wagner

Communication Networks ( ) / Spring 2011 The Blavatnik School of Computer Science, Tel-Aviv University. Allon Wagner Communication Networks (0368-3030) / Spring 2011 The Blavatnik School of Computer Science, Tel-Aviv University Allon Wagner Kurose & Ross, Chapter 3.5.5, 3.7 (5 th ed.) Many slides adapted from: J. Kurose

More information

מצליחה. 1. int fork-bomb() 2. { 3. fork(); 4. fork() && fork() fork(); 5. fork(); printf("bla\n"); 8. return 0; 9. }

מצליחה. 1. int fork-bomb() 2. { 3. fork(); 4. fork() && fork() fork(); 5. fork(); printf(bla\n); 8. return 0; 9. } שאלה : (4 נקודות) א. ב. ג. (5 נקודות) הגדירו את המונח race-condition במדוייק לא להשמיט פרטים. ספקו דוגמא. (5 נקודות) מהו? Monitor נא לספק הגדרה מלאה. ( נקודות) ( נקודות) ציינו כמה תהליכים יווצרו בקוד הבא

More information

Introduction to Programming in C תרגול 8

Introduction to Programming in C תרגול 8 Introduction to Programming in C תרגול 8 1 1 נושאים מצביעים רקע אופרטורים על מצביעים מצביעים כפרמטרים לפונקציה הקצאה דינמית מבנים תאור הזיכרון של המחשב: מצביעים ניתן לחשוב על זיכרון המחשב כעל רצף של תאים,

More information

רזח יליגרתו םי יראני ב ם

רזח יליגרתו םי יראני ב ם מבוא למדעי המחשב עצים בינאריים ותרגילי חזרה תרגול 13: עצים בינאריים - הגדרה הגדרה: עץ בינארי הוא עץ ריק )בלי צמתים( או עץ המורכב משורש ושני תתי-עצים, הוא עץ בינארי. ימני ושמאלי, שכל אחד מהם שאלה עץ בינארי

More information

הפלט אחרי הביצוע של ההוראה :what3(root)

הפלט אחרי הביצוע של ההוראה :what3(root) שאלה )18 1 נקודות( סעיף א. )11 נקודות( הפלט אחרי הביצוע של ההוראה :what3(root) 15 10 20 26 12 18 25 3 28 14 13 סעיף ב. )3 נקודות( הפונקציה what1 מוסיפה את האיבר node בסוף הרשימה ומעדכנת את ראש הרשימה *ph

More information

מבוא לתכנות ב- JAVA מעבדה 4

מבוא לתכנות ב- JAVA מעבדה 4 מבוא לתכנות ב- JAVA מעבדה 4 מה בתרגול מערכים מחרוזות מערך חד מימדי מערך הוא מבנה המחזיק סדרה של איברים מאותו טיפוס גודל המערך הוא קבוע )נקבע בעת יצירת המערך( הגישה לכל איבר היא באמצעות אינדקס למה לי מערך?

More information

Computer Programming A תרגול 9

Computer Programming A תרגול 9 Computer Programming A תרגול 9 1 מטרת התרגול הקצאת זיכרון מבנים רשימות דינאמית ניהול הזיכרון בתוכנית עד כה כל המשתנים שראינו היו לוקאליים. משך הקיום של משתנים מקומיים הוא הזמן אשר הפונקציה בה הם נמצאים

More information

Page 1 1 מס' מחברת : מס' ת.ז. : סמסטר א' תשס"ט מועד: א' 16/02/2009 משך הבחינה: שלוש שעות אין להשתמש בחומר עזר בחינה בקורס תכנות ב- C מרצים: אלון לרנר, עופר פסטרנק מתרגלים:

More information

$ gcc check.c. $ a.out. $ gcc check.c -o check. $ check. $ gcc -Wall check.c -o check. #include <stdio.h>

$ gcc check.c. $ a.out. $ gcc check.c -o check. $ check. $ gcc -Wall check.c -o check. #include <stdio.h> תכנות בסיסי בשפת C תוכנית ראשונה תוכנית ב - C מורכבת מאוסף פונקציות והגדרות טיפוסים. C איננה שפה object oriented כך שאין בה מושגים של מחלקה ואובייקט. נתחיל בתוכנית הראשונה המסורתית, זו המדפיסה הודעה יחידה

More information

מבוא לתכנות ב- JAVA תרגול 6

מבוא לתכנות ב- JAVA תרגול 6 מבוא לתכנות ב- JAVA תרגול 6 מה בתרגול )methods( פונקציות/שיטות ב- Java הגדרת פונקציה קריאה/הפעלה העברת ארגומנטים ערכי החזרה מבוא לפונקציות- שימוש חוזר בקוד נניח שבמהלך תוכנית נדרשתם לחשב את הסכום של המספרים

More information

עמוד 1 (תאריך ( âùéä ער äìàù בכל השאלות ניתן להניח שהקלט תקין. 100 íåëñ חורף :

עמוד 1 (תאריך ( âùéä ער äìàù בכל השאלות ניתן להניח שהקלט תקין. 100 íåëñ חורף : עמוד 1 מבוא למדעי המחשב מ' 234114 מבוא למדעי המחשב ח' 234117 מבחן מועד א', סמסטר חורף תשס"ב (תאריך ( 29.1.03 שם משפחה שם פרטי מס' סטודנט âùéä ער äìàù 15 1 15 2 16 3 18 4 16 5 20 6 100 íåëñ חומר עזר: אין

More information

Exams questions examples

Exams questions examples Exams questions examples 1 Exam example 1. y - x what נק' ( לפניך הפעולה הרקורסיבית מקבלת כפרמטרים שני מספרים שלמים ו 10 )? מה יהיה הפלט כתוצאה מזימון הפעולה what public static int what(int x, int y) if(x

More information

תכנות מתקדם בשפת C משתנים

תכנות מתקדם בשפת C משתנים תכנות מתקדם בשפת C משתנים 1 משתנים סוגי משתנים בשפת C ההבדלים בין סוגי המשתנים השונים 2 /* This program computes m to the power of n */ /* Assumptions: m is an integer; n is a positive integer */ #include

More information

ת ונכת סרוק תורשוקמ תומישר :יעישת רועיש 1

ת ונכת סרוק תורשוקמ תומישר :יעישת רועיש 1 קורס תכנות שיעור תשיעי: רשימות מקושרות 1 הקצאה דינאמית של מערכים דו-ממדיים )לפחות( שלוש גישות אפשריות:.1 מערך של מערכים מצביעים לתוך מערך "גדול".2 3. מצביע יחיד למערך גדול 2 The Interface 3 (Simple) Usage

More information

לאחר הרצת התכנית יופיע בחלון הoutput הפלט הבא: run: ******************************* *****Welcome to Java!***** *******************************

לאחר הרצת התכנית יופיע בחלון הoutput הפלט הבא: run: ******************************* *****Welcome to Java!***** ******************************* דוגמה 1: public class Hello { 2: public static void main(string[] args) { 3: System.out.println("*******************************"); 4: System.out.println("*******Welcome to Java!********"); 5: System.out.println("*******************************");

More information

מערכים שעור מס. 4 כל הזכויות שמורות דר ' דרור טובי המרכז האוניברסיטאי אריאל 1

מערכים שעור מס. 4 כל הזכויות שמורות דר ' דרור טובי המרכז האוניברסיטאי אריאל 1 מערכים שעור מס. 4 דרור טובי דר' כל הזכויות שמורות דר ' דרור טובי המרכז האוניברסיטאי אריאל 1 למה מערכים? ברצוננו לאחסן בתוכנית ציוני בחינה כדי לחשב את ממוצע הציונים וסטיית התקן. נניח ש 30 סטודנטים לקחו

More information

קורס תכנות כתובות בזיכרון כתובות בזכרון מצביעים וכתובות מצביעים וכתובות שיעור שביעי: מבנים, הקצאת זיכרון דינאמית האופרטור &

קורס תכנות כתובות בזיכרון כתובות בזכרון מצביעים וכתובות מצביעים וכתובות שיעור שביעי: מבנים, הקצאת זיכרון דינאמית האופרטור & כתובות בזיכרון קורס תכנות int x = 10; char c = a ; 10 784658 'a' 26537 שם x כתובת 784658 שיעור שביעי: מבנים, הקצאת זיכרון דינאמית 26537 c 1 הגדרת מצביע variable( )pointer כתובות בזכרון האופרטור & מחזיר

More information

מבוא לתכנות ב- JAVA תרגול 5. Ipc161- practical session 5

מבוא לתכנות ב- JAVA תרגול 5. Ipc161- practical session 5 מבוא לתכנות ב- JAVA תרגול 5 Ipc161- practical session 5 מה בתרגול מערכים דו ממדיים )methods( פונקציות/שיטות ב- Java הגדרת פונקציה קריאה/הפעלה העברת ארגומנטים ערכי החזרה מערך דו ממדי מערך של מערכים חד ממדיים

More information

קורס תכנות בשיעור הקודם למדנו על רקורסיה שיעור שישי: מערכים פונקציה רקורסיבית שאלה חישוב נוסחאות רקורסיביות בשפת C

קורס תכנות בשיעור הקודם למדנו על רקורסיה שיעור שישי: מערכים פונקציה רקורסיבית שאלה חישוב נוסחאות רקורסיביות בשפת C בשיעור הקודם למדנו על רקורסיה פתרנו את בעיית מגדלי הנוי בעזרת רקורסיה כלומר בעזרת פונקציה שקוראת לעצמה. רקורסיה מאפשרת לנו לפתור בעיה "גדולה" בעזרת פתרון של בעיות "קטנות" המרכיבות אותה. קורס תכנות שיעור

More information

Graph Database, think different!

Graph Database, think different! Graph Database, think different! Written by Roni Licher Winter 2014-2015 236363 - Database Systems - Technion Nodes Edges (directed or not) Properties Neo4j and Cypher 4j Graph database (Like SQL server

More information

מבוא למדעי המחשב תרגול 5: לולאות ומערכים

מבוא למדעי המחשב תרגול 5: לולאות ומערכים מבוא למדעי המחשב תרגול 5: לולאות ומערכים תוכנייה לולאת while, do while, for מערכים מערכים דו ממדיים 2 לולאות 3 תזכורת: לולאת while גוף הלולאה מתבצע שוב ושוב כל עוד התנאי מתקיים int number; scanf( %d, &number);

More information

Operating Systems. Practical Session 4 Threads

Operating Systems. Practical Session 4 Threads Operating Systems Practical Session 4 Threads 1 Threads Executed within a process. Allow multiple independent executions under the same process (container). Possible states: running, ready, blocked, terminated.

More information

ב ה צ ל ח ה! אוניברסיטת בן גוריון בנגב מספר נבחן : תאריך המבחן: כ"ה תשרי תשע"ח 15/10/17 שמות המורים: ציון סיקסיק מיועד לתלמידי : א'

ב ה צ ל ח ה! אוניברסיטת בן גוריון בנגב מספר נבחן : תאריך המבחן: כה תשרי תשעח 15/10/17 שמות המורים: ציון סיקסיק מיועד לתלמידי : א' אוניברסיטת בן גוריון בנגב מספר נבחן : תאריך המבחן: כ"ה תשרי תשע"ח 15/10/17 שמות המורים: ציון סיקסיק א' ב- C תכנות מבחן ב: 202-1-9011 מס' הקורס : הנדסה מיועד לתלמידי : א' מועד קיץ סמ' שנה תשע"ז 3 שעות משך

More information

תרגול מספר 3: מערכים

תרגול מספר 3: מערכים היום בתרגול:.1.2 תרגול מספר 3: מערכים מערך חד-מימדי: מה זה מערך ולמה צריך אותו? איך מגדירים? איך זה נראה בזכרון? דוגמאות לשימוש במערך חד-מימדי השוואה בין משתנה פרימיטיבי למשתנה שאינו פרימיטיבי מערך דו-מימדי:

More information

תרגילים ופתרונות בשפת C

תרגילים ופתרונות בשפת C תרגילים ופתרונות בשפת C הדפסה, קלט פלט משתנים כתב וערך: שייקה בילו תרגיל - 1 כתוב תוכנית המדפיסה את המשפט: * C * I Love כאשר לפניו שורת כוכביות ואחריו שורת כוכביות. int main() printf("************\n");

More information

במידה ולסעיף ניתנה תשובה ובנוסף נרשם לגבי הסעיף לא יודע/ת אזי הניקוד שיינתן

במידה ולסעיף ניתנה תשובה ובנוסף נרשם לגבי הסעיף לא יודע/ת אזי הניקוד שיינתן פקולטה: מדעי הטבע מחלקה: מדעי המחשב שם הקורס: מבוא למחשבים ושפת C קוד הקורס: 2-7028510 תאריך בחינה: שאלות חזרה למבחן. חשוב: אין להסיק ששאלות אחרות לא יכולות להישאל במבחן, אין להסיק כי נושאים מסויימים בסיליבוס

More information

else if (p.getinfo().getvotes() < c1.getvotes()) { c1 = p.getinfo()

else if (p.getinfo().getvotes() < c1.getvotes()) { c1 = p.getinfo() class BigBrother רשימה מועמדים לתחרות // candidates; private List publc void MakeVote(String name) הפעולה מקבלת שם, מוצאת את המתמודד ומוסיף לו הצבעה אחת // Node p = candidates.getfirst();

More information

תוכנה 1 טיפוסי השפה טיפוסים לא פרימיטיביים הטיפוסים הפרימיטיביים מחרוזות המרה למספרים תרגול 2: טיפוסי שפה, מחרוזות, מערכים ושגיאות

תוכנה 1 טיפוסי השפה טיפוסים לא פרימיטיביים הטיפוסים הפרימיטיביים מחרוזות המרה למספרים תרגול 2: טיפוסי שפה, מחרוזות, מערכים ושגיאות טיפוסי השפה תוכנה 1 תרגול 2: טיפוסי שפה, מחרוזות, מערכים ושגיאות טיפוסים יסודיים (פרימיטיביים): 8 טיפוסים מוגדרים בשפה שמיועדים להכיל ערכים פשוטים: מספרים שלמים: byte, short, int, long מספרים ממשיים: float,

More information

מבוא לשפת סי סוגי לולאות שבוע שעבר... תוכנייה. לולאת while דוגמא: קליטת מספר חיובי ד'/כסלו/תשע "ב. משפטי if משפטי switch סוגי לולאות בשפת C דוגמאות

מבוא לשפת סי סוגי לולאות שבוע שעבר... תוכנייה. לולאת while דוגמא: קליטת מספר חיובי ד'/כסלו/תשע ב. משפטי if משפטי switch סוגי לולאות בשפת C דוגמאות מבוא לשפת C תירגול 6: לולאות שבוע שעבר משפטי if משפטי switch 2 תוכנייה סוגי לולאות סוגי לולאות בשפת C ברמת התקשורת עם המחשב מאפשר לחזור שוב ושוב על אותה סדרת פעולות ללא שיכפול קוד ברמת התקשורת האנושית

More information

Smart Pointers Nir Adar

Smart Pointers Nir Adar 7.1.2005 גירסה 1.00 Smart Pointers מסמך זה הורד מהאתר. אין להפיץ מסמך זה במדיה כלשהי, ללא אישור מפורש מאת המחבר. מחבר המסמך איננו אחראי לכל נזק, ישיר או עקיף, שיגרם עקב השימוש במידע המופיע במסמך, וכן לנכונות

More information

תוכנה 1. תרגול מס' 3 עבודה עם מחרוזות )Strings( מתודות )Methods( העברת פרמטרים

תוכנה 1. תרגול מס' 3 עבודה עם מחרוזות )Strings( מתודות )Methods( העברת פרמטרים תוכנה 1 תרגול מס' 3 עבודה עם מחרוזות )Strings( מתודות )Methods( העברת פרמטרים שלבי הפיתוח - חזרה קצרה ישנם שני שלבים נפרדים: שלב פיתוח התוכנית בשלב זה אנו משתמשים במהדר )קומפיילר( כדי להמיר קבצי.java )קבצי

More information

Practical Session No. 14 Topological sort,amortized Analysis

Practical Session No. 14 Topological sort,amortized Analysis Practical Session No. 14 Topological sort,amortized Analysis Topological- Sort Topological sort Ordering of vertices in a directed acyclic graph (DAG) G=(V,E) such that if there is a path from v to u in

More information

Programming for Engineers in Python

Programming for Engineers in Python Programming for Engineers in Python Lecture 9: Sorting, Searching and Time Complexity Analysis Autumn 2011-12 1 Lecture 8: Highlights Design a recursive algorithm by 1. Solving big instances using the

More information

Programming for Engineers in Python

Programming for Engineers in Python Programming for Engineers in Python Lecture 9: Sorting, Searching and Time Complexity Analysis Autumn 2011-12 1 Lecture 8: Highlights Design a recursive algorithm by 1. Solving big instances using the

More information

תרגול 6 רקורסיה ותכנות מונחה עצמים

תרגול 6 רקורסיה ותכנות מונחה עצמים מבוא למדעי המחשב 2017 תרגול 6 רקורסיה ותכנות מונחה עצמים מבוא למדעי המחשב 1 ראינו בהרצאה רקורסיה תכנות מונחה עצמים: מחלקה ואובייקט שדות, בנאים ושיטות מימוש מערך דינאמי של ראשוניים בתרגול היום רקורסיה הדפסת

More information

Computer Programming Summer 2017

Computer Programming Summer 2017 Computer Programming Summer 2017 תרגול 6 פונקציות 1 פונקציות פונקציות מאפשרות שימוש בקטעי קוד כקופסה שחורה ללא צורך לדעת את פרטי המימוש )מספיק לדעת מה עושה הפונקציה ולא איך(. למשל: הפונקציה strlen מהתירגול

More information

שאלות חזרה 2 האוניברסיטה החליטה לפרסם שמות הסטודנטים המצטיינים בקורס שלנו. סטודנט מצטיין הוא סטודנט שקיבל

שאלות חזרה 2 האוניברסיטה החליטה לפרסם שמות הסטודנטים המצטיינים בקורס שלנו. סטודנט מצטיין הוא סטודנט שקיבל שאלות חזרה שאלה - 3 קבצים נתונים שני קבצים: ) קובץ נתוני הסטודנטים של הקורס שלנו, כל שורה בקובץ מכילה את הפרטים הבאים: תווים - שם הסטודנט - תווים - כתובת - 9 ספרות - מספר ת.ז. - 3 ספרות - קוד מחלקה - 3

More information

הנכות 1 םוכיס לוגרת 13 1

הנכות 1 םוכיס לוגרת 13 1 תוכנה 1 סיכום תרגול 13 1 בחינה באופק! הבחינה תכלול את כל הנושאים שכיסינו במהלך הסמסטר: כל ההרצאות כל תרגולים כל תרגילי בית חומר סגור שאלות אמריקאיות 2 קצת על מנשקים מנשק יכול להרחיב שירותים במנשק הם תמיד

More information

הוראות לנבחן גמר לבתי ספר לטכנאים ולהנדסאים סמל השאלון: תכנות מערכות ושפת סף ההנחיות בשאלון זה מנוסחות בלשון זכר, אך מכוונות לנבחנות ולנבחנים כאחד.

הוראות לנבחן גמר לבתי ספר לטכנאים ולהנדסאים סמל השאלון: תכנות מערכות ושפת סף ההנחיות בשאלון זה מנוסחות בלשון זכר, אך מכוונות לנבחנות ולנבחנים כאחד. גמר לבתי ספר לטכנאים ולהנדסאים סוג הבחינה: מדינת ישראל אביב תשס"ז, 2007 מועד הבחינה: משרד החינוך 714001 סמל השאלון: תכנות מערכות ושפת סף הוראות לנבחן א. משך הבחינה: ארבע שעות. ב. מבנה השאלון ומפתח ההערכה:

More information

הנכות 1 םוכיס לוגרת 13 1

הנכות 1 םוכיס לוגרת 13 1 תוכנה 1 סיכום תרגול 13 1 בחינה באופק! הבחינה תכלול את כל הנושאים שכיסינו במהלך הסמסטר: כל ההרצאות כל תרגולים כל תרגילי בית חומר סגור שאלות אמריקאיות 2 קצת על מנשקים מנשק יכול להרחיב יותר ממנשק אחד שירותים

More information

הנכות 1 םוכיס לוגרת 14 1

הנכות 1 םוכיס לוגרת 14 1 תוכנה 1 סיכום תרגול 14 1 קצת על מנשקים מנשק יכול להרחיב יותר ממנשק אחד שירותים במנשק הם תמיד מופשטים וציבוריים public interface MyInterface { public abstract int foo1(int i); int foo2(int i); The modifiers

More information

גיליון תשובות מספר נבחן:

גיליון תשובות מספר נבחן: גיליון תשובות מספר נבחן: 03( שאלה 1 סעיף א )02 (i) //@PRE: checkinv(other.getx(),other.gety(),other.getradius()) //@POST: getradius() other.getradius() >= // Math.max(Math.abs(getY()-other.getY()),Math.abs(getX()-

More information

כתבו קוד ב- 3 קבצי ה hpp (כתבו כהערה את שם הקובץ מעל) כך שהקוד יהיה תקין ובסגנון טוב. אין חובה

כתבו קוד ב- 3 קבצי ה hpp (כתבו כהערה את שם הקובץ מעל) כך שהקוד יהיה תקין ובסגנון טוב. אין חובה פקולטה: מדעי הטבע מחלקה: מדעי המחשב שם הקורס: מבנה זכרון ושפת ++C קוד הקורס: 7027810 תאריך בחינה: שאלות לדוגמא משך הבחינה: שעתיים שם המרצים: ד"ר אופיר פלא, ד"ר מירי בן ניסן חומר עזר: פתוח שימוש במחשבון:

More information

<exp> ::= <define> <cexp> <define> ::= ( define <var-decl> <cexp> ) / DefExp(var:VarDecl, val:cexp)

<exp> ::= <define> <cexp> <define> ::= ( define <var-decl> <cexp> ) / DefExp(var:VarDecl, val:cexp) הנחיות כלליות: תאריך הבוחן: 10.5.2018 שם המרצה: מני אדלר,מיכאל אלחדד, ירון גונן מבחן בקורס: עקרונות שפות תכנות מס' קורס: 202-1-2051 מיועד לתלמידי: מדעי המחשב והנדסת תוכנה שנה: ב' סמסטר: ב' משך הבוחן: 2

More information

נוסחאון מיקרובקר 8051 גרסה: 0.1

נוסחאון מיקרובקר 8051 גרסה: 0.1 נוסחאון מיקרובקר 8051 גרסה: 0.1 נכתב ע"י: מוטי פרלמוטר הוראות העברת מידע MOV A,Rn Move register to Accumulator 1 1 MOV A,R5 העבר תוכן אוגר בנק R5 לתוך A MOV A,direct Move direct byte to Accumulator 2 1

More information

תרגול 3 מערכים ופונקציות

תרגול 3 מערכים ופונקציות מבוא למדעי המחשב 2017 תרגול 3 מערכים ופונקציות מערכים מאפשרים עבודה עם מקבצים של נתונים פונקציות מאפשרות אבסטרקציה והאחדה של הקוד ראינו בהרצאה מערכים הצהרה, אתחול, גישה לאיברים במערך יצוג בזיכרון ובטבלת

More information

סטודנטים יקרים הפתרונות מוגשים בסרטוני וידאו המלווים בהסבר קולי, כך שאתם רואים את התהליכים בצורה מובנית, שיטתית ופשוטה, ממש כפי שנעשה בשיעור פרטי.

סטודנטים יקרים הפתרונות מוגשים בסרטוני וידאו המלווים בהסבר קולי, כך שאתם רואים את התהליכים בצורה מובנית, שיטתית ופשוטה, ממש כפי שנעשה בשיעור פרטי. סטודנטים יקרים לפניכם ספר תרגילים בקורס ארגון ותכנות המחשב (שפת אסמבלי). הספר הוא חלק מפרויקט חדשני וראשון מסוגו בארץ במקצוע זה, המועבר ברשת האינטרנט.On-line הקורס באתר כולל פתרונות מלאים לספר התרגילים.

More information

תוכנה 1 סמסטר א' תשע"א

תוכנה 1 סמסטר א' תשעא General Tips on Programming תוכנה 1 סמסטר א' תשע"א תרגול מס' 6 מנשקים, דיאגרמות וביטים * רובי בוים ומתי שמרת Write your code modularly top-down approach Compile + test functionality on the fly Start with

More information

תרגול 7 רשימות משורשרות, רקורסיית

תרגול 7 רשימות משורשרות, רקורסיית מבוא למדעי המחשב 2018 תרגול 7 רשימות משורשרות, רקורסיית זנב 1 ראינו בהרצאה רשימות משורשרות רקורסיית זנב 2 בתרגול היום רשימות משורשרות עוד שיטות מחלקה רקורסיית זנב היפוך מחרוזות, חיפוש בינארי 3 רשימות משורשרות

More information

הוראות לנבחן סף ובהם שמונה שאלות. עליך לענות על שש שאלות, על פי ההנחיות בכל פרק. גמר לבתי ספר לטכנאים ולהנדסאים

הוראות לנבחן סף ובהם שמונה שאלות. עליך לענות על שש שאלות, על פי ההנחיות בכל פרק. גמר לבתי ספר לטכנאים ולהנדסאים גמר לבתי ספר לטכנאים ולהנדסאים סוג הבחינה: מדינת ישראל אביב תשע"ב, 2012 מועד הבחינה: משרד החינוך 714001 סמל השאלון: תכנות מערכות בשפת C ושפת סף הוראות לנבחן א. משך הבחינה: ארבע שעות. ב. מבנה השאלון ומפתח

More information

תוכנה 1 בשפת Java נושאים שונים בהורשה רובי בוים ומתי שמרת בית הספר למדעי המחשב אוניברסיטת תל אביב

תוכנה 1 בשפת Java נושאים שונים בהורשה רובי בוים ומתי שמרת בית הספר למדעי המחשב אוניברסיטת תל אביב תוכנה 1 בשפת Java נושאים שונים בהורשה רובי בוים ומתי שמרת בית הספר למדעי המחשב אוניברסיטת תל אביב Today Static vs. Dynamic binding Equals / hashcode String Immutability (maybe) 2 Static versus run-time

More information

תוכנה 1 תרגול מספר 13

תוכנה 1 תרגול מספר 13 1 תוכנה 1 תרגול מספר 13 ו- HashCode Equals עוד על טיפוסים מוכללים )Advanced Generics( חריגים )Exceptions( בית הספר למדעי המחשב אוניברסיטת תל אביב 1 2 ו- HASHCODE EQUALS 3 תזכורת: המחלקה Object package

More information

תוכנה 1 תרגול מספר 13

תוכנה 1 תרגול מספר 13 1 2 תוכנה 1 תרגול מספר 13 ו- HashCode Equals עוד על טיפוסים מוכללים )Advanced Generics( ו- HASHCODE EQUALS חריגים )Exceptions( בית הספר למדעי המחשב אוניברסיטת תל אביב 1 3 4 package java.lang; תזכורת: המחלקה

More information

פרק 15 טיפוס חדש: מבנים שימוש במבנים שימוש במבנים שימוש במבנים

פרק 15 טיפוס חדש: מבנים שימוש במבנים שימוש במבנים שימוש במבנים פרק 15 ב- C מבנים טיפוס חדש: מבנים 1 מבנה (structure) הוא טיפוס מורכב בשפת C (בניגוד לטיפוס בסיסי). זהו טיפוס שמיועד לאיחוד קבוצת משתנים תחת שם אחד. משתנים אלו נקראים השדות של המבנה, והם יכולים להיות מטיפוסים

More information

מבוא למדעי המחשב תרגול 8 רשימה משורשרת כללית, Comparator

מבוא למדעי המחשב תרגול 8 רשימה משורשרת כללית, Comparator מבוא למדעי המחשב 2017 תרגול 8 רשימה משורשרת כללית, Comparator בתרגול היום. LinkedList בניית ההכללה מ- LinkIntList תרגול המבנה ושימושיו ממשקים: Comparator Sorted Linked List ל- LinkedList ע"י שימוש ב- Comparator

More information

עקרונות שפות תכנות 2016 תרגול 8 Type Inference System. Substitution Interpreter.

עקרונות שפות תכנות 2016 תרגול 8 Type Inference System. Substitution Interpreter. עקרונות שפות תכנות 2016 תרגול 8 Type Inference System. Substitution Interpreter. Type Inference System The Type Inference System is a Scheme Implementation of the algorithm for Type Checking and Inference

More information

הקלחמ ה תמרב ת ונ וכ ת (static members ) יליזרב דהוא Java תפשב ם דקת מ תונכת ביבא ל ת תטיסרבינוא

הקלחמ ה תמרב ת ונ וכ ת (static members ) יליזרב דהוא Java תפשב ם דקת מ תונכת ביבא ל ת תטיסרבינוא ת כו נו ת ברמת ה מחלקה (static members) אוהד ברזילי תכנות מ תקד ם בשפת Java אוניברסיטת ת ל אביב static keyword שדות המוגדרים כ static מציינים כי הם מוגדרים ברמת המחלקה ולא ברמת עצם כל העצמים של אותה מחלקה

More information

3 Dynamic Routing A (RIP and OSPF)

3 Dynamic Routing A (RIP and OSPF) אוניברסיטת בן גוריון בנגב המחלקה להנדסת מערכות תקשורת רשתות תקשורת מחשבים - 2 קורס 37110211 מעבדה בתקשורת מחשבים 3 Dynamic Routing A (RIP and OSPF) בשבוע (29/11/2011) 5 בשבוע (13/12/2011) 7 מעבדה מספר

More information

Tutorial 10. Introduction to C++ שימו

Tutorial 10. Introduction to C++ שימו Introduction to ++ שימו תרגול זה אינו התרגול הרישמי של הקורס. הוא מבוסס על חוברת התרגולים אך מכיל שינויים, הסברים נוספים ודוגמאות שונות או נוספות. + + תוכנ ית רא שונה ב הכרו ת עם + + תרגול // First ++

More information

Solution for Data Structure

Solution for Data Structure Solution for Data Structure May 2016 INDEX Q1 a 2-3 b 4 c. 4-6 d 7 Q2- a 8-12 b 12-14 Q3 a 15-18 b 18-22 Q4- a 22-35 B..N.A Q5 a 36-38 b N.A Q6- a 39-42 b 43 1 www.brainheaters.in Q1) Ans: (a) Define ADT

More information

הנכות 1 םוכיס לוגרת 13 1

הנכות 1 םוכיס לוגרת 13 1 תוכנה 1 סיכום תרגול 13 1 קצת על מנשקים מנשק יכול להרחיב יותר ממנשק אחד שירותים במנשק הם תמיד מופשטים וציבוריים public interface MyInterface { public abstract int foo1(int i); int foo2(int i); The modifiers

More information

תרגול 3 מערכים ופונקציות

תרגול 3 מערכים ופונקציות מבוא למדעי המחשב 2018 תרגול 3 מערכים ופונקציות מערכים מאפשרים עבודה עם מקבצים של נתונים פונקציות מאפשרות אבסטרקציה והאחדה של הקוד ראינו בהרצאה מערכים הצהרה, אתחול, גישה לאיברים במערך יצוג בזיכרון ובטבלת

More information

מבוא למדעי המחשב הרצאה 2: ראשונים בשפת C

מבוא למדעי המחשב הרצאה 2: ראשונים בשפת C מבוא למדעי המחשב צעדים הרצאה 2: ראשונים בשפת C מבוסס על שקפים שנערכו ע"י שי ארצי, גיתית רוקנשטיין ז"ל, איתן אביאור, סאהר אסמיר,מיכאל אלעד, רון קימל ודן רביב. עדכון אחרון: יחיאל קמחי, אוקטובר 2014 תוכנייה

More information

מבוא לתכנות ב- JAVA מעבדה 3. Ipc161-lab3

מבוא לתכנות ב- JAVA מעבדה 3. Ipc161-lab3 מבוא לתכנות ב- JAVA מעבדה 3 Ipc161-lab3 נושאי התרגול ניפוי שגיאות לולאות בדיקת תרגילים בקורס )השוואת פלטים למול הפתרון המצופה( כיצד להפנות את פלט התוכנית לקובץ טקסט איך להשוות תכנים של שני קבצים בעזרת

More information

דף הדרכה ליצירת שרת/ לקוח עם GUI

דף הדרכה ליצירת שרת/ לקוח עם GUI דף הדרכה ליצירת שרת/ לקוח עם GUI בשיעורים הקודמים למדנו כיצד ליצור שרת לקוח פשוט, ויצירת טופס המכיל פקדים כלומר יצירת GUI למשתמש, בשיעור זה נרצה להראות את הדרך לשילוב בין השניים כלומר ליצור לקוח client

More information

מבוא לתכנות מערכות מבחן מועד א' סמסטר חורף

מבוא לתכנות מערכות מבחן מועד א' סמסטר חורף הפקולטה למדעי המחשב פרופ' גיל ברקת נועם שגב, שרי דואק, רן ברואר, דור כהן הטכניון מכון טכנולוגי לישראל 70.70.07.4 מבוא לתכנות מערכות 024.00 מבחן מועד א' סמסטר חורף 07.207.4 הוראות כלליות משך המבחן: 081

More information

Chapter 11.2 Linked lists ( )

Chapter 11.2 Linked lists ( ) Lecture of Geiger & Itai s slide brochure www.cs.technion.ac.il/~dang/courseds מערכים, מטריצות דלילות, ורשימות מקושרות חומר קריאה לשיעור זה Chapter. Linked lists ( ) Geiger & Itai, מערך מוגדר ע"י הפעולות

More information

Tirgul 4 Scheduling:

Tirgul 4 Scheduling: Question 1 [Silberschats 5.7] Tirgul 4 Scheduling: Consider the following preemptive priority scheduling algorithm based on dynamically changing priorities. Larger priority numbers imply higher priority.

More information

קורס תכנות רשימה מקושרת דוגמה: חיפוש מעבר על רשימה דוגמא: שחרור רשימה מקושרת דוגמא: הוספת אברים שלא בהתחלה

קורס תכנות רשימה מקושרת דוגמה: חיפוש מעבר על רשימה דוגמא: שחרור רשימה מקושרת דוגמא: הוספת אברים שלא בהתחלה רשימה מקושרת רשימה היא אוסף סדור של ערכים פעולות רשימה לעומת מערך קורס תכנות שיעור עשירי: מיונים, חיפושים, קצת ניתוח זמני ריצה, קצת תיקון טעויות ועוד על רשימות 3 5 7 9 typedef struct node int data; struct

More information

Simple Web Service. namespace MyService { public class Service1 : System.Web.Services.WebService {

Simple Web Service. namespace MyService { public class Service1 : System.Web.Services.WebService { Simple Web Service WS פתיחת פרוייקט File New Project ASP.Net web service project - >http://localhost/webservice1 יצירת שירות המחשב חיבור וחילוק 2 מספרים : הטיפוסים הבסיסיים using System; איסוף וניהוף אוספי

More information

מבוא למדעי המחשב 2018 תרגול 7

מבוא למדעי המחשב 2018 תרגול 7 מבוא למדעי המחשב 2018 תרגול 7 רשימות משורשרות, רקורסיית זנב 1 ראינו בהרצאה רשימות משורשרות רקורסיית זנב 2 בתרגול היום רשימות משורשרות עוד שיטות מחלקה רקורסיית זנב היפוך מחרוזות, חיפוש בינארי 3 רשימות משורשרות

More information

הנכות 1 תואיגש םע תודדומתהו תואלול,םי : כרעמ 2 לוגרת

הנכות 1 תואיגש םע תודדומתהו תואלול,םי : כרעמ 2 לוגרת תוכנה 1 תרגול 2: מערכים, לולאות והתמודדות עם שגיאות מערכים מערכים Array: A fixed-length data structure for storing multiple values of the same type Example from last week: An array of odd numbers: Indices

More information

more...3 less...3 prompt...3

more...3 less...3 prompt...3 עמוד 1 מתוך 24 ls...3 passwd...3 pwd...3 man...3 finger...3 cat...3 pico...3 rm...3 cp...3 mv...3 history...3 chmod...3 ln (hard link)...3 ln -s (soft link)...3 cal...3 find...3 wc...3 head...3 tail...3

More information